<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body>
    <!-- 
    Props
      概念：是一种特殊的 attributes 。 需要在组件内通过 props 选项来声明，然后使用组件时可以传递该 prop。组件内收到的 prop 可以当成组件普通的数据一样拿到模板中直接使用或通过this获取得到。
   -->
    <div id="app">
      <hello name="张三" age="18"></hello>

      <hello name="里斯" age="20"></hello>
    </div>

    <script src="../lib/vue-3.js"></script>
    <script>
      const app = Vue.createApp({});

      app.component("hello", {
        template: `
          <div>欢迎，{{ name }} - {{ age }}</div>
        `,
        /**
         * 用于声明哪些 attr 是 prop
         * 语法：
         *    1. props: [prop1, prop2]
         *    2. props: {
         *      key: value
         *    }
         */
        props: ["name", "age"],
        mounted() {
          console.log(this.name);
        },
      });

      app.mount("#app");
    </script>
  </body>
</html>
